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(57) Abstract 

A network (20) of ATM routing switches (21) transmits digital signal cells of a first type requiring integrity of transmission and 
a second type accepting some loss in transmission, each switch has buffer circuitry (35), a plurality of output ports (30) each having a 
plurality of queues of cells awaiting output, each output port having control circuitry (40) to provide in an output frame control bits (60, 62) 
indicating the type of cell, a path identifier and the existence of flow congestion at the routing switch (21) which is outputting the frame, 
thereby inhibiting transmission of further frames to that location until a frame is received from that location indicating that the congestion 
is cleared. 
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IMPROVEMENTS IN OR RELATING TO AN ATM SWITCH 

The invention relates to routing switches for the transmission of digital signals and to methods 
of switching digital signals through routing switches. The invention is particularly applicable 
to ATM switches and methods of operating ATM switch networks. 

Data communications in digital form are commonly used for distribution of data between 
computers and in telecommunications for the transmission of voice signals. Distributed 
computing systems have used Local Area Networks (LANs) but the requirement to provide 
wider networks has led to the need for reliable telecommunications networks which can 
support computer data as well as traditional voice traffic. Existing telephone networks have 
been designed to transmit voice traffic around the globe and such systems have been 
optimised for low band width with low latency between sender and receiver although the 
traffic is relatively insensitive to noise and data errors. Local area networks which have been 
used for computer communication have generally operated over relatively short distances but 
require high band width for computer data and in this case the data is not necessarily sensitive 
to latency but must avoid data errors or omissions. To mix the two communication 
requirements in a signal network, Broadband Integrated Services Digital Network systems 
have been proposed and in particular Asynchronous Transfer Mode (ATM) systems have been 
proposed using small self-routing packets of digital signals. 

It is an object of the present invention to provide improved routing switches together with 
improved methods of switching data packets through a network of routing switches and is 
particularly applicable to ATM switches and systems. 

Reference in this specification to a switch for bi-directional transmission of digital signals 
means a switch such that when two are connected together each may output a digital signal 
to the other. Switch 1 may act as a source of digital signals sent to switch 2 acting as a 
destination while switch 2 may act as a source of digital signals sent to switch 1 acting as a 
destination. The reference to source and destination may each be intermediate in an extended 
network of switches. 
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The invention provides a network of interconnected routing switches, each switch being 
arranged for bi-directional transmission of digital signal cells of at least two types, a first type 
requiring integrity of cell transmission while accepting variable bit rate of transmission, and 
a second type accepting some loss of cells in transmission, which switch has a plurality of 
input ports for receiving input cells from a plurality of sources, a plurality of output ports for 
outputting output cells to a plurality of destinations, buffer circuitry selectively connectable 
to both said input and output ports for holding a plurality of cells of each type after receipt 
by an input port and prior to output by an output port, and control circuitry comprising 
congestion detecting circuitry, and output circuitry responsive to said congestion detecting 
circuitry and operable to output each cell in a bit frame which includes control bits, whereby 
one routing switch provides an output frame at a selected output port with control bits which 
indicate at an input of a second connected routing switch (i) data for use in determining which 
type of cell is included in the frame (ii) a path identifier for use in determining the path of 
the cell through said second routing switch and (iii) the existence of flow congestion in the 
said one routing switch, said control circuitry further including input circuitry responsive to 
said control bits to detect indication of congestion at selected sources and to inhibit output of 
cells from an output port to any destination location from which an indication of congestion 
has been input, until a frame is received from that location acting as a source indicating that 
the congestion is cleared. 

Preferably said output circuitry is operable to form a plurality of queues of cells awaiting 
output at each port. 

Preferably said input circuitry is responsive to said control bits to identify an output port for 
use by the switch and a destination output port for an adjacent connected switch in the 
network, said output circuitry forming a plurality of queues at a single output port, each of 
said plurality of queues having a different destination port for the next switch in the network. 

Preferably said output circuitry operates selectively to output cells from a plurality of queues 
at a single output port so as to output preferentially cells from any queue having a destination 
for which no flow congestion indicator has been received. 

Preferably said congestion detecting circuitry comprises counting means to monitor queue 
lengths at one or more output ports. 



WO 98/09473 



PCT/GB97/02340 



3 

Preferably said congestion detecting circuitry includes counter iheans for detecting the number 
of cells of selected different types that axe held in said buffer circuitry. 

Preferably each switch includes designation circuitry to provide a respective designation to 
each input port, which is used to determine permitted paths to avoid deadlock in the network, 
each cell which is input having the designation of the respective input port, said control 
circuitry being responsive to said designations to output to a connected input of a further 
switch in the network only cells of a designation compatible with the designation of said 
connected input. 

Preferably said designation circuitry is arranged to allocate one of a plurality of designations 
forming an ordered sequence for use within the network, said control circuitry being operable 
to output a cell of any given designation only to a connected input which itself has a 
designation at the same, or a more advanced, position in said ordered sequence. 

The invention includes a method of transmitting digital signal cells through a network of 
interconnected routing switches, said signal cells comprising at least two types, a first type 
requiring integrity of cell transmission while accepting variable bit rate of transmission, and 
a second type accepting some loss of cells in transmission, which method comprises receiving 
at a plurality of input ports of one switch input cells from a plurality of sources in other 
switches in the network, outputting cells from a plurality of output ports in one switch to a 
plurality of destinations in other switches in the network, holding a plurality of cells of each 
type in buffer circuitry in one switch after receipt by an input port and prior to output by an 
output port, testing for congestion of cells within the switch and operating output circuitry to 
output a cell from an output port in a bit frame which includes control bits, said output 
circuitry providing an output frame at a selected output port with control bits which indicate 
at an input of a second connected routing switch (i) data for use in determining which type 
of cell is included in the frame (ii) a path identifier for use in determining the path of the cell 
through said second routing switch and (iii) the existence of flow congestion in the said one 
routing switch, said second routing switch responding to said control bits to detect indication 
of congestion at the source of the cell and inhibiting output of cells from an output port of 
said second switch to any destination location from which an indication of congestion has 
been input, until a frame is received from that location acting as a source indicating that the 
congestion is cleared. 
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The method may include forming a plurality of queues of cells awaiting output at each port. 
Said plurality of queues having respective different priorities, the method may include putting 
a cell on a queue at only one selected output port. 

The method may include putting a cell on queues at a plurality of output ports. 

Preferably said input circuitry responds to said control bits to identify an output port for use 
by the switch and a destination output port for an adjacent connected switch in the network, 
and forming a plurality of queues at a single output port, each of said plurality of queues 
having a different destination port for the next switch in the network. 

Preferably output of cells from a plurality of queues at a single port is controlled so as to 
output preferentially cells from any queue having a destination for which no flow congestion 
indicator has been received and not cleared. 

The queue lengths at one or more output ports may be counted in order to generate said 
congestion indication. 

The number of cells of selected different types held in the buffer may be counted in order to 
generate a congestion indication. 

Preferably both queue lengths at the output ports and the number of cells in the buffer are 
counted to generate the congestion indication. 

Preferably the method includes providing a respective designation to each input port on each 
switch, which designation is used to determine permitted paths to avoid deadlock in the 
network, each cell which is input having the designation of the respective input port, and 
operating said control circuitry to output a cell of any given designation only to an input port 
of a connected switch having a compatible designation. 
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An embodiment of the invention will now be described by way of example and with reference 
to the accompanying drawings in which :- 

Figure 1 is a block diagram of an ATM switch system in accordance with the invention, 
Figure 2 is a block diagram of one routing switch for use in the system of Figure 1, 
Figure 3 shows schematically a communication path through two routing switches of the 

apparatus of Figure 1, 
Figure 4 shows the format of one cell frame used in the system of Figure 1, 
Figure 5 illustrates the operation of part of the frame of Figure 4, 

Figure 6 shows in further detail the operation of the part of the frame shown in Figure 5, 
Figure 7 shows an alternative operation of the part of the frame shown in Figure 5, 
Figure 8 shows a further operation of the part of the frame shown in Figure 7, 
Figure 9 shows an alternative operation of the part of the frame shown in Figure 7, 
Figure 10 illustrates a queue system for the routing switch of Figure 2, 
Figure 1 1 shows the operation of a further part of the frame of Figure 4 in forming the queues 
of Figure 10, 

Figure 12 shows further detail of the operation of the queues of Figure 10, 

Figure 13 illustrates the memory system used to identify the queues of Figure 10, 

Figure 14 shows memory partitioning for a memory used in Figure 2, 

Figure 15 illustrates part of the frame format of Figure 4 used for flow control, 

Figure 16 illustrates schematically the arrangement of Figure 2 when flow control tokens of 

Figure 15 are operating, 
Figure 17 shows a further part of the frame of Figure 4 used to control congestion, 
Figure 18 shows further details of the operation of congestion control of Figure 17, 
Figure 19 is a schematic diagram showing more detail of the routing switch of Figure 2 and 
Figure 20 shows a scheme of permitted connections in a network of switches in accordance 

with the invention, 

Figure 21 shows an alternative interconnection between two routing switches of the type 
shown in Figure 2. 
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The embodiment described relates to a communication network including a plurality of 
routing switches which may be applied to ATM and LAN interconnection and backbones as 
well as Broadband Network Access systems (including ATM PABX and switched digital 
disbritution systems) PC/workstation terminal adaptor cards and Residential 
digital video. The system is arranged to transmit self routing packets of digital signals 
through a plurality of routing switches in a network. Each packet comprises a data cell in a 
multi byte frame including control bits which are used in determining the route of the packet 
through each switch as well as the characteristics required in handling transmission of that 
packet. The packets may be of varying types depending on the priority required for various 
transmission characteristics for the packet. For some communications such as voice traffic, 
the priority may be for constant bit rate (CBR). Another type of traffic may tolerate variable 
bit rate (VBR). For computer communications the latency or time variation between 
successive packets may not be important but avoidance of errors or loss of data may have 
highest priority. For such communication an unknown bit rate (UBR) or best available bit 
rate (ABR) may be an acceptable or preferred characteristic for the data transmission. 

The embodiment described is arranged to handle any of the above types of communication 
and each packet contains control bits to determine the manner in which the transmission of 
the packet will be handled through each routing switch. The routing switches may be used 
as elements of an ATM switch. 

Each routing switch has a plurality of bi-directional ports for input and output of packets 
together with an on chip buffer for storing packets while forming queues of packets awaiting 
output at one or more of the ports. Packets may be allocated one of a plurality of traffic 
priorities and the system permits any one packet to be put on a queue for a single output port 
(unicast) or to be put on queues of more than one output port (multicast). Management of 
the routing switch chip can be controlled by an external CPU chip connected to a management 
port of the routing switch. This may control the allocation of buffer space on the routing 
switch chip to partition the buffer capacity for different types of traffic. Thresholds for cell 
delay variation and priority for cell disgarding in the event of congestion, can be programmed 
on the chip by use of external CPU control. 
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A schematic network of routing switches in accordance with the present invention is shown 
in Figure I. This example shows three ATM terminals 11,12 and 13 which may be arranged 
to input or output voice signals, video signals or computer data in digital form, or any mixture 
of them. Each terminal is connected to a respective interface 14, 15 and 16 by bi-directional 
links 17. Each interface is connected to the ATM switch fabric 20 which in this case 
comprises three interconnected routing switches 21, 22 and 23. Each routing switch is 
connected to other switches in the fabric by a plurality of bi-directional serial links each 
comprising four wires. Two wires in each direction carry respectively data and strobe signals. 
Programming of the routing switches in the switch fabric is controlled by a control CPU 25 
which is connected to each of the switches by bi-directional links 26. Each interface 14, 15 
and 16 is connected to a respective one of the switches 21, 22, 23 in the switch fabric by a 
bi-directional serial link 27. 

Figure 2 shows a simplified block diagram of one routing switch 21. This comprises a single 
chip device having a plurality of ports 30 each providing an output/input link. Each link has 
two output wires 3 1 and 32 providing serial data paths for data and strobe signals respectively. 
Each link also has two input wires 33 and 34 each providing serial data paths for data and 
strobe signals which are input to the switch. Data packets which are received by the switch 
are stored in a memory providing a cell buffer pool 35 connected by on chip buses 36 to the 
ports 30. Each port 30 is connected by a bus to input process circuitry 37 to handle incoming 
packets. Circuitry 38 is provided for each port to identify queues of processes stored in the 
buffer 35 awaiting output by the associated port 30. The chip also includes system service 
circuitry 39, management and control circuitry 40 as well as cell pool control circuitry 41. 
A routing table 42 is provided in memory on the chip for use in determining the route of 
selected packets transmitted through the chip. 

It will be understood that the routing switches in any ATM switch fabric can be connected 
in any desired configuration. In the present example the maximum number of switches which 
may be connected in sequence between two interfaces is three. In other embodiments other 
numbers of switches may be connected between any two interfaces. 

In Figure 3, one possible connection of switches 21 and 23 is shown between the interfaces 
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14 and 15. In this case, each of the interfaces 14 and 15 may be as described in French 
Patent Application No. 9604315. 

Each interface has a substantial RAM 50 connected to the interface so that data packets may 
be stored at the interface if a further routing switch or terminal is not ready to receive the data 
packet from the interface. In the connection shown in Figure 3, ATM cells are supplied to 
interface 14 and temporarily stored in the RAM 50 connected to the interface 14. Cells which 
are output from RAM 50 are fed along the data path 51 which is connected to a selected input 
port of switch 21. The cells are held in the pool 35 of switch 21 and then output on data path 
52 from a selected output port of switch 21 to a selected input port of switch 23. The cell 
is then stored in the buffer 35 of switch 23 until output from a queue of a selected output port 
of switch 23 along data path 53 to the interface 15. The cell then is stored in RAM 50 
connected to interface 1 5 until a further ATM switch network or a terminal receives the cell 
from interface 15 on datapath 54. 

The bit format of each packet is shown in Figure 4. The packet consists of a frame 62 bytes 
long. The frame consists of a header which is 6 bytes long followed by an ATM ceil 52 
bytes long giving the data which represents the communication to be made by transmission 
of the packet. The frame includes a trailer which is 4 bytes long. 

In Figure 4 the header is marked 60, the data cell is marked 61 and the trailer is marked 62. 
Most of the header remains unchanged throughout the transmission of the packet through a 
succession of routing switches. The header is applied to the packet by the interface, such as 
interface 14, at the input side of the switch network. The header generally determines the 
selection of ports which will be used on transmission of the packet through the switch 
network as well as the handling characteristics to be applied to the packet during that 
transmission. The trailer 62 is however applied at the output port of each routing switch to 
indicate to the next routing switch in the transmission path, any congestion at the routing 
switch which has just provided the source of that packet. Consequently the trailer will be 
changed on output of the packet by each successive routing switch in order to indicate the 
state of the outputting routing switch. 



98094 73A1J_> 



WO 98/09473 



PCT/GB97/02340 



9 

The fields of the header 60 are as follows. The first two bits are marked AT and represent 
the address type. The next 20 bits are marked PSI representing the path selection identifier. 
If AT has the value 1 then PSI is used to give the explicit address of the output ports required 
for three successive routing switches. If AT has the value 0 then the value of PSI is used to 
provide an implicit address. That will be described in more detail below. Two bits are 
marked EPS and this value is used to interpret the PSI value in the case of explicit addressing. 
This will be described in more detail below. After a reserved bit, three bits are marked VFI. 
These act as a Virtual FIFO identifier and will be described later in the selection of output 
queues for each cell. To control the discard of CBR cells in the event of congestion, two bits 
are marked CGT to identify a congestion threshold, one bit is marked CGA to identify what 
action is to be taken when congestion occurs and a further bit marked CGI can be set during 
transmission of a cell to indicate that congestion has arisen. Sixteen bits marked V2V form 
an interface to interface field for use in cooperation between the inputting interface 14 and 
the outputting interface 15. The data of the communication itself forms the central cell 61. 
The trailer 62 has four bits marked CRC which are used for a cyclic redundancy check by the 
interfaces. A further five bits marked CLE are used as a cell loss estimator and again this 
information is used by the interfaces 14 and 15 to check on the total number of cells sent and 
received by the interfaces as described in French Patent Application No 9604315. The 
remaining bits of the trailer are used for flow control purposes to control flow of ABR cells 
from one routing switch to another when congestion occurs. Twenty-two of those bits are 
marked FCT and form a flow control token. The remaining bit marked Ti is used to identify 
which of two priorities, the flow control bits refer to as will be described later. 

PORT SELECTION 

When a packet is input at a port of a routing switch either from an interface or from another 
routing switch, the input process circuitry 37 decodes data in the header 60 of the packet in 
order to determine whether the cell should be accepted or discarded. If accepted, the header 
information is used to determine which port or ports the cell should be output from, and 
which queue should be used at the selected output port or ports. As already explained, if the 
AT value is 1, then explicit addressing is used. In this case the PSI value forms four output 
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port numbers each identified by five bits. The first three numbers are shown in Figure 5 and 
each identifies a respective port number for three successive stages of routing switches. As 
illustrated in Figure 5, the three successive stage indicators 65, 66 and 67 each identify a 
respective one of the eighteen possible output ports of successive routing switches. The 
determination of which of the three elements 65, 66 and 67 shown in Figure 5 relates to 
which successive routing switch stage is determined by the EPS value. The EPS acts as a 
pointer for each routing switch to indicate which five bit element of the PSI value is to be 
used by that routing switch to identify the output port. At each switching step the EPS value 
is decreased by one so as to point to successive five bit elements of the PSI on moving from 
one switch to the next. As the input process circuitry 37 of each switch decodes the relevant 
element of the PSI to identify the output port required for that switch, it substitutes for that 
element of the PSI a value indicating the input port used to input that packet. This assists 
identification of the forward frame sender. The fourth element of the PSI which is not used 
by the three successive routing switches is used in routing the cell through the output 
interface. Figure 6 shows the use of element 65 to select port 70 of a routing switch 71 
whereas element 66 is used to select output port 72 of a second stage switch 73 and element 
67 is used to select an output port 74 of a third stage switch 75. 

In all the above examples of explicit addressing, the PSI value results in the cell being put 
on a queue at only one output port of each routing switch so that the cell is unicast. 

In cases where AT has a value 0 implicit addressing is used. In this case only twelve bits of 
the PSI indicator are used and they address a location in the routing table 42 of the switch. 
The routing table 42 comprises a writable memory into which values have been loaded from 
the control CPU 25. The PSI value points to a selected address in the routing table as shown 
in Figure 7 and an implicit tag 80 is read out from the table to the cell pool control circuitry 
41. The format of this tag is shown more fully in Figure 8. The tag comprises twenty bits. 
Bit 0 is marked F. If F has the value 0 then the cell is to be multicast and thereby put onto 
a queue at more than one output port. If F has the value 1 then the cell is unicast and the cell 
will be put on one or more queues but only at a single output port. The remaining nineteen 
bits identify respective output ports. Bit 1 identifies port 0 which is used only for 
management purposes. The remaining bits 2-19 identify respectively ports 1-18 which are 
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used for the output of data packets. If the bit location of the tag has the value 1 then that 
output port is to be used. If the bit location has the value 0 then the corresponding port is 
not to be used. Figure 9 shows the position where the implicit tag 80 has a value F=l so 
that the cell is to be unicast. In this case bit locations 15-19 identify the output port to be 
used by the routing switch which has input this packet. Bit locations 10-14 identify the 
output port to be used by the next routing switch in the succession of routing switches used 
in the network. In this way, implicit tag identifies the output ports to be used by two 
successive routing switches. 



QUEUE SELECTION 



Having identified the required output port or ports for each cell which is input, it is necessary 
to decide which queue or queues the cell is to be put on at the selected output port or ports. 
As illustrated in Figure 10, each routing switch, such as switch 21, has nineteen output ports 
30. Port 0 is used for internal management purposes and ports 1-18 are used to communicate 
data for the message transmitted through the switch fabric. Each output port 30 can handle 
eight different priorities marked F0-F7. Each port may have a queue or queues for cells of 
each of these different designated priorities. Any cells with priority F0 will be treated with 
the highest priority so that they are output from the output port in preference to cells taken 
from queues of lower priority. For each of priorities F0-F5 only one queue is permitted per 
port. Each of those queues can handle either CBR cells or ABR cells. However each queue 
will consist only of cells of the same selected type. For priorities F6 and F7 each has one 
standard queue for CBR or ABR cells similar to F0-F5. Each of the queues for priorities F0 
to F7, which may be used for ABR or CBR, is allocated to controlled traffic (e.g. ABR) 
which is controlled by flow control tokens, or to uncontrolled traffic (e.g. CBR) which is 
subject to discard rather than flow control. The allocation of each priority level to one or 
other of these types is controlled by the control CPU 25 storing required values in a queue 
allocation register 95 indicating which priority level is available to controlled or uncontrolled 
traffic. Register 95 also contains indicators to subdivide the uncontrolled traffic into more 
than one priority level. In this example, CBR traffic may have two different priority levels 
CBR0 and CBRL Register 95 holds values to indicate which of priorities F0-F7 are allocated 
to CBR0 and which are allocated to CBRl. In this way, the priority indicator in the header 
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of each frame, together with the data loaded into register 95, will indicate whether the traffic 
is controlled or uncontrolled and what its priority level is. 

For priority F6, an additional nineteen queues F6.0-18 can be provided only for controlled 
ABR traffic. Each one of those queues corresponds to a designated output port for the next 
routing switch in the succession of routing switches. Similarly for priority F7, an additional 
nineteen queues F7.0-18 can be provided only for controlled ABR traffic, each queue 
corresponding to a designated output port of the next routing switch in the succession of 
switches. Queues F6.0 and F7.0 are used for packets carrying out internal management 
functions only and designated for port 0 of the next switch. Cells which are put on any one 
of the queues F6.0-18 or F7.0-18 can only be ABR cells which are unicast. The other 
queues may be unicast or multicast. It was seen in relation to Figure 9 that ABR cells which 
were unicast obtained an indication from the implicit tag 80 (bit positions 10-14) of the 
selected port for the next routing switch in the succession of routing switches. Consequently, 
any routing switch handling an implicit tag of the type shown in Figure 9 will know which 
output port to use for the present routing switch and which output port will be required for 
the next routing switch. Consequently, cells of that type can be put onto a selected queue for 
priority F6.0-18 or priority F7.0-18, the selected queue being designated specifically for a 
selected one of the output ports of the next switch in the sequence. This assists in avoiding 
head of line blocking. In other words, some cells of priority F6 or F7 may be destined to be 
transmitted through an output stage of a subsequent switch at which congestion is occurring. 
Any such cell at the head of a queue will prevent output of other cells which may be destined 
for subsequent output ports which are not blocked. Hence the queue will be blocked by the 
head of line entry. By providing a plurality of separate queues for each of priorities F6.0-18 
and F7.0-1 8, each queue being dedicated to a specific different output port of the next routing 
switch, those queues which are destined for non-congested output ports downstream can be 
output without delay. 

The selection of queue is determined as shown in Figure 11. The VFI indicator from the 
header 60 provides a numerical value corresponding to one of the priorities F0-F7. This in 
combination with the decoding of the PS1 value allows correct selection of the required output 
port or ports and the correct one of the several possible queues F0-F7 at the selected output 
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port or ports. If the decoding of the header indicates that the cell is a unicast ABR cell of 
priority 6 or 7 with identification of the next switch output port then it is added to the correct 
one of the possible nineteen queues for either priority F6.0-18 or priority F7.0-18 depending 
on the next switch output port identified from the implicit tag shown in Figure 9. 

It will therefore be seen that each output port has the possibility of forty six simultaneous 
queues. One queue for each of priorities F0-F5 and twenty queues for each of priorities F6 
and F7. 

Figure 10 also indicates that the control circuitry 39, 40 and 41 includes a number of counters 
and threshold stores for use in flow control and congestion control. Counters 90 are provided 
for counting numbers of different types of cells in the buffer 35. A store 91 is provided for 
setting threshold values for various types of cells in the buffer 35. Counters 92 are provided 
for responding to the queue length per port. A store 93 is provided to set threshold values 
for the per port queue length indicated by the counters 92. 

In addition, it is necessary for flow control to identify the direction in which cells are passing 
through any one switch in a sequence of swtiches. In this example, each switch is capable 
of handling cell transmission in two opposite directions along a linear chain shown in Figure 
3. One of these directions will be referred to as the up direction and the other as the down 
direction. The ports 30 are correspondingly identified either as an up direction port or a down 
direction port depending on the direction in which a cell is being transmitted through that 
port. This will be explained more fully in relation to the operation of the buffer 35. In order 
to identify the designation of each of the ports 30, an up/down control register 94 is provided 
to identify each port as an up direction port or a down direction port and each cell is buffered 
as an up cell or a down cell depending on the designation of port through which it was input. 

The avoidance of head of line blocking is further illustrated in Figure 12. In this case an 
incoming cell 100 having priority F6 or F7 is put onto the appropriate queue FX.0-FX.18 at 
port n marked 101. This is an output port of a switch at stage m in the network. The output 
port 101 is connected to an input port of switch at stage m+1 . Nineteen different queues at 
port n are each directed at a respective different output port of the switch at stage m+1. If 
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any one of the output ports of stage m+1 has a queue which reaches a threshold indicating 
congestion then a flow control mechanism using the previously described flow control tokens 
is operated to indicate to the switch at stage m that any of the queues FX.0-FX.18 which are 
destined for a congested port of stage m+1 should not be output until the congestion is cleared 
by receipt of a frame travelling from stage m+1 to stage m indicating clearance of the relevant 
port of stage m+1. 

MECHANISM FOR IDENTIFYING QUEUES 

The manner in which the cells in the buffer 35 are identified for each queue at an output port 
is illustrated in Figure 13. The buffer 35 is 62 bytes wide so that it holds one frame per row. 
The buffer can hold 512 rows. Various rows will be holding a cell ready for output while 
other rows are empty awaiting input of a cell and these empty rows have free addresses 
indicated by a free address queue for use by the input control circuitry. The output control 
circuitry 38 and cell pool control circuitry 41 includes writeable memory as shown in Figure 
13. That includes a respective memory table for each port giving a queue descriptor for each 
queue at that port. These memory regions are marked 111 for port 1 to 128 for port 18. A 
separate management queue descriptor is provided in memory region 129 and a free address 
queue descriptor is provided in memory region 130. The list of queue descriptors is generally 
similar for each port and will be described with reference to the memory region 111 for port 
1. This includes a list of descriptors. One descriptor 131 is provided for each single queue 
of priorities F0-F5. For priority F6 twenty descriptors 132 are provided for each of the 
twenty queues referred to in Figure 10 for priority F6. Similarly twenty descriptors 133 are 
provided for each of the queues for priority F7. Each of the descriptors in memory region 
111 comprise a front of queue pointer 135 and a back of queue pointer 136. A second 
writeable memory region 134-138 is provided for each port. Each memory region 134-138 
has row locations corresponding to row locations of the buffer 35. In Figure 13 memory 
region 134 relates to port 1 and similar memory regions are provided for each port up to 
memory region 138 provided for port 18. A management memory region 139 is identified 
by the management queue descriptor 129 and a free address memory region 140 is pointed 
to by the free address queue descriptor 130. The operation of each memory region 134-138 
as well as 139 and 140. is generally similar and will be described with reference to region 1 34 
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relating to port 1. The front descriptor 135 indicates the row location of memory region 134 
corresponding to the cell in buffer 35 which is at the head of the queue. That identifies the 
first cell to be taken by that queue when it is output. The region 134 which was pointed to 
by the front pointer 135 indicates the next buffer row to locate the second cell to be output 
in that queue. As each cell in the queue is located, the corresponding row of memory region 
134 identifies the location of the next cell for that queue. This progresses until the last cell 
in the queue is located by the back pointer 136. Although the location of that cell can be 
identified in the buffer 35, the corresponding row of memory region 134 does not have an 
indication of a next address for a cell in that queue until a further cell is added to that queue. 
At that time the back pointer 136 will be adjusted. The queue handling for management cells 
which are transmitted through port 0 are handled in a similar way by the descriptor 129 and 
the memory list 139. Similarly the list of free addresses in the buffer 35 for use by incoming 
cells to the buffer 35 is handled by the descriptor 130 and list 140. 

It will therefore be seen that the memory regions 134-138 form a plurality of linked lists each 
for a respective one of the output ports. Each location in the list provides a link to the next 
cell in the queue so that a thread of identification of successive cells in a queue is provided 
through the memory locations in each of the lists 134-138. The linking of each sequence 
through the memory regions 134-138 causes the memory regions to act as virtual FIFO's. 

It will be understood that for each of priorities F0-F5, a single thread of cell identifiers 
forming a queue exists in each of the memory regions 134-138. However, for priorities F6 
and F7, a plurality of threads exists through each of the memory regions 134-138. That 
plurality of threads for each memory region consists of a discrete thread for each of the 
queues F6.0-18 and F7.0-18 as well as for the standard F6 and F7 queue holding either ABR 
or CBR. In the case of the multiple threads existing for the queues F6.0-18 and F7.0-1 8, the 
cells identified on these lists are ABR unicast cells so that they are identified only on a single 
one of the memory regions 134-138 corresponding to the selected one output port through 
which the cell can be output. Furthermore, each cell on a list where multiple threads exist 
on the same memory region 134-138, will only occur on one thread on that memory region 
as it is unicast both for the present switch which is outputting the cell and also on the next 
switch in the sequence. Consequently no ambiguity arises in locating next addresses on the 
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multiple threads which are held on the same memory region 134-138. 



In the case of priority F0-F5 as well as the standard queues (holding CBR or ABR) for F6 
and F7, these queues may incorporate multicast cells so that the same cell may be located on 
more than one queue and thereby more than one thread. However in this case any plurality 
of threads which identify the same cell will be located on different memory regions 134-138 
corresponding to the relevant output port. Consequently the separate lists maintained on the 
separate memory regions 134-138 enable the correct next cell to be located for any queue 
regardless of which queue caused the removal of the cell from the buffer 35. 



BUFFER PARTITIONING 



To handle effectively a variety of traffic requiring different handling characteristics such as 
CBR and ABR, it is important that the buffer space on the switch chip does not get used by 
only one class of traffic or by one particular port. Consequently it is necessary to monitor 
congestion within the buffer itself and congestion at any particular port to initiate either cell 
discard action for CBR cells or flow control for ABR cells once a switch becomes overloaded 
or approaches that condition for any particular type of cell. To optimise the share of buffer 
capacity between different types of traffic, a number of partitions are set up in the buffer 35 
to limit the acceptable capacity of the number of cells stored of each of a number of 
designated types of packet. Firstly a partition 150 is set up to indicate the maximum of CBR 
cells that may be held in the buffer. Within that partition two separate partitions 151 and 152 
are set up for respective different priorities of CBR cells designated CBRO and CBR1. On 
input of a CBR cell the switch may designate different priorities dependant on the 
programming of the register 95 and the VFI indicator in the frame header so that a cell is held 
either as a high priority CBRO cell or a lower CBR1 cell. A region within the partition 150 
is marked 153 representing an overlap region which may be used by cells of either CBRO or 
CBR1 designation. A further partition 160 within the buffer 35 is allocated to ABR cells. 
As already explained, cells may have been designated as up or down cells. In case of ABR 
cells, congestion will result in flow control tokens being included in a packet travelling in an 
up direction in order to control flow of packets back to the switch in the down direction. 
Similarly for packets flowing in the down direction flow control tokens are used to prevent 
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packets flowing back to the same switch in the up direction. To avoid deadlock caused by 
flow control operating in opposition directions simultaneously on the same switch, it is 
necessary to check on congestion for ABR cells flowing in the up and down directions 
separately. For this reason the partition 160 has sub-partitions to handle separately buffer 
allocation for ABR signals in the up direction and the down direction. It is also advantageous 
monitor the congestion separately for ABR cells of priority 0-5 from those of priority 6-7. 
For this reason, partition 160 includes four separate partitions 161, 162, 163 and 164 which 
provide guaranteed buffer space up to their threshold values for ABR cells respectively of 0-5 
up, 6-7 up, 0-5 down and 6-7 down. A further overlap region 165 is provided which may 
be used for cells of any of the types represented by partitions 161, 162, 163 and 164. There 
are also overlap regions for use by any of these ABR cells between the partitions 161, 162, 
163 and 164. When the cells stored in any of the regions 161-165 reach the threshold values 
set for these partitions, flow control tokens are created to limit further input of cells of that 
type to the switch buffer. However there is inevitably a time delay in the restricted flow 
becoming operative as the flow control cannot be instantaneous. For this reason a margin 
partition 1 66 is provided to handle any incoming ABR cells which were en-route to the switch 
prior to other switches responding to the flow control tokens. 

The cell capacity for each of the partitions set up in the buffer of Figure 14 is determined by 
a respective threshold store value held in store 91 shown in Figure 10. These threshold values 
may be set by the control CPU 25. The content of the buffer 35 is monitored by counters 90 
(Figure 10) and compared with the threshold values stored in the store 91. In addition to 
monitoring the numbers of cells stored in the buffer 35 as a whole, counts are also carried out 
on a per port basis. Each port has three counters (92 in Figure 10). One counter provides 
a count of the total number of CBR0 cells that form a queue at that port. A second counter 
gives a count of the total number of CBR1 cells that form a queue at that port. The third 
counter for each port counts the aggregate number of ABR cells of priority 6 and 7 that is 
awaiting output by that port. A threshold count for each of these three counters is also held 
in a store 93 shown in Figure 10. Comparison of the counted values with the threshold values 
for either the total buffer values or the per port values may be used to cause the input or 
output circuitry of the switch to initiate discard action for incoming cells or output of flow 
control tokens to limit arrival of further cells. In the case of the counter 92 which counts the 
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aggregate length of queues of ABR 6 and ABR 7 cells, this does not need to count the two 
different priority queues separately. Priority 6 is higher than priority 7. Consequently, the 
threshold value for the number of priority 7 cells is set lower than that for the permitted 
number of priority 6 cells. As soon as the aggregate reaches the threshold value for priority 
7 cells, flow control tokens are output to inhibit further input of ABR priority 7 cells for that 
port so that more priority 6 cells can still be accepted until the count reaches that set for the 
aggregate of priority 6 and priority 7. 

To avoid deadlock due to the flow control mechansim, the above example operates with 
controlled flow in the up and down directions. Ceils which are stored in an up partition of 
the buffer can go to an up or a down partition of the buffer of an adjacent switch in the 
network. Any cells which are held in a down partition of a buffer can only go to a down 
partition of an adjacent switch. An input interface connected to a switch network must always 
supply the cell to an up region of the buffer of the first switch connected to the interface. 
The output interface at the end of the switch sequence can receive a cell from 
either a down or an up partition of the buffer of the last switch in the sequence. 

FLOW CONTROL FOR ABR CELLS 

When any counters establish that inhibition of ABR flow must commence, a flow control 
token to restrict flow is generated by the output circuitry of the switch and forms part of the 
trailer of the packet that is output from the switch. The format of the flow control token is 
illustrated in Figure 15. The manner in which this acts in the switch network is illustrated 
schematically in Figure 16. Figure 16 corresponds to the arrangement shown in Figure 3. 
In this case, switch 21 has a threshold level 170 set for a particular type of ABR traffic and 
that threshold has been reached by the relevant type of traffic stored in the pool 35. In the 
case illustrated switch 21 cannot output further traffic of that type to the next switch 23 in the 
sequence as switch 23 has also a buffer content for that same type of traffic which has 
reached the threshold level 171 set for switch 23. Consequently flow control tokens passing 
from switch 23 back to switch 21 along line 172 indicate back pressure to switch 21 to inhibit 
further flow of cells of that type from switch 21 to switch 23. As switch 21 is full of cells 
of that type, it also emits flow control tokens, thereby indicating back pressure, along line 1 73 
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to the input interface 14. This inhibits interface 14 from sending any further cells of that 
designated type to switch 21 until the back pressure 173 has been cleared. In the meantime, 
any further ATM cells 175 arriving at the interface 14 are stored in the RAM 50 associated 
with the interface 14. The RAM 50 may have a programmed threshold indicated at 176 but 
as illustrated the content of the RAM 50 does not exceed level 177 so that the RAM 50 may 
store these cells until the switch network is capable of taking further cells from the interface. 

The bit format of the flow control token is shown in Figure 15. The first bit 180 is marked 
Ti and is used only as a selector bit and will be described below. The next eighteen bits 181 
are used to indicate port congestion for any one of the ports 1-18 based on the aggregate 
queue lengths for priority F6 for that port or the aggregate of queue lengths for priority F7 
at that port. The selector bit 180 is used to indicate whether the set of bits 181 relate to 
priority F6 or priority F7. If Ti is set to the value 0 then the per port control indicated by 
bits 1-18 relate to the aggregate queue lengths of priority 6. If Ti is set to the value 1, then 
bits 1-18 indicate congestion at the respective ports for queue lengths of priority 7. 

The next bit 1 82 shown in Figure 1 5 is used to indicate congestion within the buffer partitions 
for multicast ABR cells having priority 6 or 7. Again the value set by the selector bit 180 
determines whether bit 182 relates to congestion for priority F6 or F7. The counters 90 
referred to in Figure 10 include a counter for multicast ABR signals of priority F6 and F7 
which are held in the buffer although no separate partition is illustrated in Figure 14. A 
threshold value for these multicast counts will also be set in the threshold store 91. It will 
be appreciated that all the counters used for congestion and flow control are arranged to 
increment the count by 1 as the buffer inputs a new cell of the respective type and allocates 
it to a particular queue. The counter is decremented as a cell of that type is output from the 
switch. 

The next bit 183 shown in Figure 15 indicates whether congestion occurs for the number of 
ABR cells of priority 6 and 7 held in the partitions 162 or 164 of the buffer shown in Figure 
14. The last bit 184 is used to indicate whether congestion occurs for ABR cells of priority 
0-5 held in the partitions 161 and 163 of the buffer shown in Figure 14. In the case of each 
of bits 182, 183 and 184 it is necessary to distinguish between cells moving in the upward 
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direction or the downward direction. In the case of the multicast ABR signals of priority 6 
or 7, separate counts are held for appropriate cells in both the upward and downward 
directions. The values held in bit locations 182, 183 and 184 apply to cells in the up or down 
direction in dependence on the value held in register 94 of Figure 1 0 identifying whether the 
congestion applies to cells in the up or down direction. 

CBR CONGESTION CONTROL 

In the case of CBR traffic, any congestion detected in the buffer 35 or at any of the ports 30, 
will result in some congestion control determined by information in the header 60 of each 
packet. This will be explained with reference to Figure 17 showing the relevant part of the 
header. In that Figure, bits 12 and 13 indicate a CGT value and the operation of this is 
explained with reference to Figure 18. The CGT value indicates an offset value from the 
threshold values set for the buffer 35 or the ports 30. As illustrated in Figure 18 the CGT 
value may be 0, 1 , 2 or 3. If CGT=0 then the offset value per port is 4 and per switch buffer 
is 8. For CGT=1 the offset values are 8 per port and 16 per switch buffer. For CGT=2 the 
offset values are 16 per port or 32 per switch buffer. For CGT=3 the offset values are 32 per 
port or 64 per switch buffer. This indicates that if the per port count of CGT cells reaches 
the offset value from the threshold set, either for the count on a per port basis or for the count 
set within the buffer partition, then some form of congestion action is required. The type of 
action then taken depends on the value set by the CGA bit shown in Figure 17. If CGA has 
the value 0 then the cell should be discarded. Further cells may arrive from adjacent switches 
or interfaces and each cell as it is input will be tested in the same way to see whether or not 
it should be accepted into the switch buffer or discarded. If however CGA=1 and the CGT 
value indicates that the offset from the threshold has now been reached, then the cell is 
accepted into the switch buffer for onward transmission but the CGI indicator at bit position 
15 in Figure 17 is set to the value 1. That bit then remains unchanged for the remainder of 
the transmission of the packet through the switch fabric so as to indicate that the path of that 
type of cell is nearly congested. 
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SWITCH LAYOUT 

A more detailed block diagram of the switch layout is shown in Figure 19. Similar parts have 
similar reference numerals to the earlier figures. In this case each of the ports 30 has been 
split to show the input operations at the left hand side of the figure and the output operations 
from the same ports at the right hand side of the figure. This comprises a plurality of input 
buffers 190 each having a capacity to hold an entire frame. The management circuitry 40 
controls decoding of each frame held in an input buffer so that data from the frame header 
is supplied along line 191 to input control circuitry 192 to determine the write address in the 
cell buffer pool 35. That write address is determined from the free address queue 140. The 
date to be written in is supplied to the pool on line 193 from the data section 61 of each 
frame. The input control circuitry 192 has a two-way connection to the routing table 42 in 
the case of cells using implicit addressing. Output buffers 195 each having a capacity to hold 
a full frame are loaded with data under the control of output control circuitry 196. The output 
control circuitry 196 responds to the management queue 139 to provide read addresses to the 
buffer 35 and the data read out on line 197 is loaded into the appropriate output buffer 195. 
The output control 196 also receives on line 199 any flow control tokens which have been 
extracted from the input data received by the input buffers 190. In response to flow control 
tokens received on line 199, the output control circuitry 196 may inhibit the further output 
of selected types of cells from the output buffers 195. Both the input control circuitry 192 
and output control circuitry 1 96 are connected to the counters 90 and 92 and if it is necessary 
to generate flow control tokens these may be output from the output control circuitry 196 on 
line 200 so as to be included in the trailers of frames which are output from the output buffers 
195. The management circuitry 40 includes a port 201 for connection to the control CPU 25 
and a test port 202. 

The above example describing avoidance of deadlock relates to a linear chain having two 
opposite directions called up and down. However the invention is applicable to other 
networks of the type shown in Figure 20 where a plurality of switches, each similar to those 
described in Figures 2 or 19, are connected in a non-linear configuration. In the example 
shown in Figure 20, three switches 210, 211 and 212 are connected between three similar 
interfaces each marked 14. Although each of the switches will have a plurality of ports, for 
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simplicity only four are shown on each switch. For example on switch 210 the ports are 
marked Sll, SI 2, S13 and SI 4. Each is a bi-directional port in that it can take input or give 
output signals through the port. To avoid deadlock it is necessary for each switch to include 
registers similar to register 94 in Figure 10 in order to designate each input port with a 
respective type or direction. Depending on the complexity of the network, a plurality (for 
example 2, 3 or more) of types or directions must be specified and each type or direction 
forms one part of an ordered sequence. This will be determined by the control CPU 25 in 
Figure 1 and programmed into the corresponding register 94 of each switch. Once the 
ordered sequence for each designated type or direction of input port has been specified, each 
switch can only output cells in accordance with the order of the sequence. Each cell as it 
is input through a port is designated as a cell of the type corresponding to the designation of 
the input port through which the cell was input. The buffer is partitioned with separate 
categories corresponding to each type or direction designated for a port so that the buffer of 
Figure 14 is modified to provide separate categories for each direction or type of input port 
that is designated. Each switch can then output a cell of a designated type only to an input 
port of an adjacent switch which does not run counter to the ordered sequence of types. 
Consider for example output port S13 of switch 210 in Figure 20 outputting a cell to the input 
port S21 of switch 211. The output port S13 will ascertain the type or direction designated 
to the cell which it wishes output. It can only do so to a designated input port S21 of switch 
211 if the input port S21 has a type or designation at the same position in the ordered 
sequence or is further advanced in the order sequence. The output of any cell having a 
specific type or designated direction, can be output to a receiving input which forms any part 
of the ordered sequence either at the same position in the sequence as the designation of the 
cell itself or to an input port having a designation further advanced along the sequence, but 
never retrogressive in respect of the designation of the output cell in the sequence. Each of 
the switches shown in Figure 20 is arranged so that the connection between the output port 
and input port of each switch is constrained to output cells of a designated type or direction 
only to inputs of a designated type or direction which meet the above conditions. 

' The invention is not limited to the details of the foregoing example. For instance, any 
combination of switches may be interconnected in a network between appropriate input and 
output interfaces. The header information to determine routing through the switch network 



°*JRDOOID * <rWO 9809473A1 I > 



WO 98/09473 PCT/GB97/02340 

23 

may be modified to provide necessary information for a different number of switches in the 
network. To provide a higher bandwidth connection between connected switches in the 
network consecutive links can be connected as shown in Figure 20 to provide a high band- 
width bus connection between selected links on two adjacent switches. Such a grouped 
connection is illustrated at 202 between two switches 21 and 22 in Figure 21. 
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CLAIMS: 



1. A network of interconnected routing switches, each switch being arranged for bi- 
directional transmission of digital signal cells of at least two types, a first type requiring 
integrity of cell transmission while accepting variable bit rate of transmission, and a second 
type accepting some loss of cells in transmission, which switch has a plurality of input ports 
for receiving input cells from a plurality of sources, a plurality of output ports for outputting 
output cells to a plurality of destinations, buffer circuitry selectively connectable to both said 
input and output ports for holding a plurality of cells of each type after receipt by an input 
port and prior to output by an output port, and control circuitry comprising congestion 
detecting circuitry, and output circuitry responsive to said congestion detecting circuitry and 
operable to output each cell in a bit frame which includes control bits, whereby one routing 
switch provides an output frame at a selected output port with control bits which indicate at 
an input of a second connected routing switch (i) data for use in determining which type of 
cell is included in the frame (ii) a path identifier for use in determining the path of the cell 
through said second routing switch and (iii) the existence of flow congestion in the said one 
routing switch, said control circuitry further including input circuitry responsive to said 
control bits to detect indication of congestion at selected sources and to inhibit output of cells 
from an output port to any destination location from which an indication of congestion has 
been input, until a frame is received from that location acting as a source indicating that the 
congestion is cleared. 

2. A network according to claim 1 wherein said output circuitry is operable to form a 
plurality of queues of cells awaiting output at each port. 

3. A network according to claim 2 wherein said input circuitry is responsive to said 
control bits to identify an output port for use by the switch and a destination output port for 
an adjacent connected switch in the network, said output circuitry forming a plurality of 
queues at a single output port, each of said plurality of queues having a different destination 
port for the next switch in the network. 

4. A network according to claim 2 or claim 3 wherein said output circuitry operates 
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selectively to output cells from a plurality of queues at a single output port so as to output 
preferentially cells from any queue having a destination for which no flow congestion 
indicator has been received. 

5. A network according to any one of the preceding claims in which said congestion 
detecting circuitry comprises counting means to monitor queue lengths at one or more output 
ports. 

6. A network according to any one of the preceding claims in which said congestion 
detecting circuitry includes counter means for detecting the number of cells of selected 
different types that are held in said buffer circuitry. 

7. A network according to any one of the preceding claims in which each switch includes 
designation circuitry to provide a respective designation to each input port, which is used to 
determine permitted paths to avoid deadlock in the network, each cell which is input having 
the designation of the respective input port, said control circuitry being responsive to said 
designations to output to a connected input of a further switch in the network only cells of 
a designation compatible with the designation of said connected input. 

8. A network according to claim 7 in which said designation circuitry is arranged to 
allocate one of a plurality of designations forming an ordered sequence for use within the 
network, said control circuitry being operable to output a cell of any given designation only 
to a connected input which itself has a designation at the same, or a more advanced, position 
in said ordered sequence. 

9. A method of transmitting digital signal cells through a network of interconnected 
routing switches, said signal cells comprising at least two types, a first type requiring integrity 
of cell transmission while accepting variable bit rate of transmission, and a second type 
accepting some loss of cells in transmission, which method comprises receiving at a plurality 
of input ports of one switch input cells from a plurality of sources in other switches in the 
network, outputting cells from a plurality of output ports in one switch to a plurality of 
destinations in other switches in the network, holding a plurality of cells of each type in 
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buffer circuitry in one switch after .receipt by an input port and prior to output by an output 
port, testing for congestion of cells within the switch and operating output circuitry to output 
a cell from an output port in a bit frame which includes control bits, said output circuitry 
providing an output frame at a selected output port with control bits which indicate at an input 
of a second connected routing switch (i) data for use in determining which type of cell is 
included in the frame (ii) a path identifier for use in determining the path of the cell through 
said second routing switch and (iii) the existence of flow congestion in the said one routing 
switch, said second routing switch responding to said control bits to detect indication of 
congestion at the source of the cell and inhibiting output of cells from an output port of said 
second switch to any destination location from which an indication of congestion has been 
input, until a frame is received from that location acting as a source indicating that the 
congestion is cleared. 

10. A method according to claim 9 including forming a plurality of queues of cells 
awaiting output at each port. 

11. A method according to claim 10 wherein said plurality of queues have respective 
different priorities. 

12. A method according to claim 10 or claim 1 1 wherein said input circuitry responds to 
said control bits to identify an output port for use by the switch and a destination output port 
for an adjacent connected switch in the network, and forming a plurality of queues at a single 
output port, each of said plurality of queues having a different destination port for the next 
switch in the network. 

13. A method according to any one of claims 10 to 12 wherein output of cells from a 
plurality of queues at a single port is controlled so as to output preferentially cells from any 
queue having a destination for which no flow congestion indicator has been received and not 
cleared. 

14. A method according to any one of claims 9 to 13 wherein queue lengths at one or more 
output pons are counted in order to generate said congestion indication. 
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15. A method according to any one of claims 9 to 14 in which the number of cells of 
selected different types held in the buffer are counted in order to generate a congestion 
indication. 

16. A method according to any one of claim 9 to 15 including providing a respective 
designation to each input port on each switch, which designation is used to determine 
permitted paths to avoid deadlock in the network, each cell which is input having the 
designation of the respective input port, and operating said control circuitry to output a cell 
of any given designation only to an input port of a connected switch having a compatible 
designation. 

17. A method according to claim 16 in which a respective designation of an ordered 
sequence of designations is allocated to each cell when input through an input port of the 
switch and said control circuitry operates to output a cell of a given designation only to an 
input port of a connecting switch which has a designation at the same position, or a more 
advanced position, in the ordered sequence. 
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